OpenStack Liberty : Configure Swift (Control Node)
2015/12/28 |
Configure OpenStack Object Storage (Swift).
This example shows to configure like the environment below.
| +------------------+ | +-----------------+ | [ Control Node ] |10.0.0.30 | 10.0.0.50| [ Proxy Node ] | | Keystone |-----------+-----------| | +------------------+ | +-----------------+ | +---------------------------+--------------------------+ | | | |10.0.0.71 |10.0.0.72 |10.0.0.73 +-------+----------+ +--------+---------+ +--------+---------+ | [Storage Node#1] | | [Storage Node#2] | | [Storage Node#3] | | |-------| |-------| | +------------------+ +------------------+ +------------------+ |
[1] | Add Swift user or service on Keystone Server (Control Node) first. |
# add swift user root@dlp ~(keystone)# openstack user create --domain default --project service --password servicepassword swift +--------------------+----------------------------------+ | Field | Value | +--------------------+----------------------------------+ | default_project_id | ba3f5997c2474c13b36e6f6bc47a264c | | domain_id | default | | enabled | True | | id | 22db77b43c4940a99e85bad596218c29 | | name | swift | +--------------------+----------------------------------+ # add swift user in admin role root@dlp ~(keystone)# openstack role add --project service --user swift admin
# add an entry for swift service root@dlp ~(keystone)# openstack service create --name swift --description "OpenStack Object Storage" object-store +-------------+----------------------------------+ | Field | Value | +-------------+----------------------------------+ | description | OpenStack Object Storage | | enabled | True | | id | 9bf898dda27c48d28b67b50d713eee56 | | name | swift | | type | object-store | +-------------+----------------------------------+ # define the IP address of Proxy Node root@dlp ~(keystone)# export swift_proxy=10.0.0.50
# add an entry for swift endpoint (public) root@dlp ~(keystone)# openstack endpoint create --region RegionOne object-store public http://$swift_proxy:8080/v1/AUTH_%\(tenant_id\)s +--------------+---------------------------------------------+ | Field | Value | +--------------+---------------------------------------------+ | enabled | True | | id | 105a6d6634e94d2ca50df9a5690385af | | interface | public | | region | RegionOne | | region_id | RegionOne | | service_id | 9bf898dda27c48d28b67b50d713eee56 | | service_name | swift | | service_type | object-store | | url | http://10.0.0.50:8080/v1/AUTH_%(tenant_id)s | +--------------+---------------------------------------------+ # add an entry for swift endpoint (internal) root@dlp ~(keystone)# openstack endpoint create --region RegionOne object-store internal http://$swift_proxy:8080/v1/AUTH_%\(tenant_id\)s +--------------+---------------------------------------------+ | Field | Value | +--------------+---------------------------------------------+ | enabled | True | | id | 48cee8ea96db429fb2930b8d557284ad | | interface | internal | | region | RegionOne | | region_id | RegionOne | | service_id | 9bf898dda27c48d28b67b50d713eee56 | | service_name | swift | | service_type | object-store | | url | http://10.0.0.50:8080/v1/AUTH_%(tenant_id)s | +--------------+---------------------------------------------+ # add an entry for swift endpoint (admin) root@dlp ~(keystone)# openstack endpoint create --region RegionOne object-store admin http://$swift_proxy:8080/v1 +--------------+----------------------------------+ | Field | Value | +--------------+----------------------------------+ | enabled | True | | id | eaeb35c24bc0417c86a16914e958e1d6 | | interface | admin | | region | RegionOne | | region_id | RegionOne | | service_id | 9bf898dda27c48d28b67b50d713eee56 | | service_name | swift | | service_type | object-store | | url | http://10.0.0.50:8080/v1 | +--------------+----------------------------------+ |